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Ad Hoc Communications System 

This invention relates to ad hoc networking applications, in which a number 
5 of communications devices co-operate to form a communications network. There are 
two basic types, namely many-to-many communication, wherein the devices 
communicate mainly between themselves, and ad hoc edge networking, wherein the 
devices interface with conventional fixed networks through interface or edge devices. 
The communications devices form nodes of a wireless network, allowing data to be 

10 relayed from an originating communications device to a destination communications 
device, by way of other communications devices. Such devices have a number of 
applications in circumstances where the communications devices are likely to be 
moving in unpredictable ways. A particular application scenario is a sensor network, 
in which data is collected from a network of mobile sensor devices, each of which is 

15 capable of taking measurements and relaying packets of data. Such devices are used 
by scientists taking measurements of the behaviour of the atmosphere, the sea, ice 
caps, lava flows or wildlife. The environments in which such devices are required to 
operate often have measurement points widely dispersed in both space and time. 
Some of the environments are hostile to human life. In some applications, such as the 

20 study of animal behaviour, human intervention could compromise the data. For these 
reasons the devices must be capable of operating autonomously, and transmitting the 
data they collect to a more convenient point using a wireless medium such as radio 
or sonar. Moreover it is not usually possible to provide a continuous power supply, so 
the useful life of a device is primarily constrained by battery life. 

25 Other applications for such ad hoc networks, to which the invention might be 

applied, include "tagging" technology for monitoring the health of patients and the 
elderly in the community, or of the location of people subject to court orders 
restricting their movements. More generally, ad hoc networks can be made up of 
wireless laptop computers or mobile telephones in close proximity to each other. 

30 Military personnel, police or other emergency services could also use the invention 
when attending an incident where there are insufficient channels for all the users to 
communicate directly with the fixed base stations provided in the vicinity. In these 
cases, more conventional communication devices could become part of ad hoc 
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Network Routing Protocols" , Proceedings of the Fourth Annual ACM/IEEE 
International Conference on Mobile Computing and Networking, Mobicom '98, 
October 1998, Dallas, Texas), has shown widely differing results in the size of 
routing overhead. The total overhead is greatest for TORA, and becomes 
5 unacceptably large for a network size of thirty source devices. 

Moreover, all of these prior art protocols require large processor and memory 
capacities, and their protocols do not take account of the energy usage required. 
Energy usage, along with memory and processor capacity, are particularly important 
in sensor networks. These typically consist of very small, very cheap 

10 microprocessors, e.g. 16 bit, with 32 kilobytes of RAM. They also have a finite 
battery supply, which would be impractical to replace given the nature of the 
applications in which the sensors are to be used. It is therefore very important that 
any communication protocol is energy-efficient aware, and also pared to a minimum 
in communication overhead and memory usage. In other applications, battery and 

15 memory usage are also important considerations: a user would be unwilling to allow 
his mobile telephone to form part of such an ad hoc network if other users caused a 
significant drain on either of these resources whilst his own device was not actively 
engaged in a call. 

A number of lightweight ad hoc routing protocols have been proposed. The 
20 work by Toh already discussed describes a wireless communication network, and a 
scheme to maximise the battery life of ad hoc devices in the network. S Singh, M 
Woo and C Raghavendra, have made a detailed study of power-conservation in ad 
hoc networks at the MAC and network layers ('Tower-Aware Routing in Mobile Ad 
hoc Networks". Proceedings of the Fourth Annual ACM/IEEE International Conference 
25 on Mobile Computing and Networking (MobiCom), (Dallas, TX, Oct. 1998)). They 
include schemes for devices to power-down in between expected transmissions, and 
they take into account device load as an important factor in power consumption. 
Their main concern is to prevent network partitioning when gaps appear in the 
network as a result of devices running out of battery power. Work by WB 
30 Heinzelman, AP Chandrakasan and H Balakrishnan considers sensor networks 
specifically. ("Energy-Efficient Routing Protocols for Wireless Microsensor Networks", 
Proceedings of the 33rd International Conference on System Sciences (HICSS '00), 
January 2000). This work assumes variable device broadcast range. Their focus is on 
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the use of clustering techniques to reduce bandwidth usage by, for example, data 
aggregation of similar data, and using predictable transmission times, co-ordinated by 
the cluster heads. This approach saves significant energy, compared with an always- 
on approach, but the routing side is simplistic and not fully developed. In particular, 
5 their experimental scenario assumes the devices could all broadcast to the base 
station if they chose to do so, which would not be realistic, in general, for sensor 
network applications. Work by A Cerpa, J elson, D Elstrin, L Girod, M Hamilton and J 
Zhao, refers to habitat monitoring as a driver for wireless communications 
technology, and focuses on power-saving by having devices switching themselves on 

10 and off according to whether they are in the vicinity of regions where interesting 
activity is expected, or detected by other devices. ("Habitat Monitoring: Application 
Driver for Wireless Communications Technology", ACM SIGCOMM Workshop on 
Data Communications in Latin America and the Caribbean, Costa Rica, April 2001. 
Work by Y. Xu, J. Heidemann, and D. Estrin again focuses on using powered- down 

1 5 modes for devices to conserve power, based on whether payload data is predicted or 
not, and on the number of equivalent devices nearby that could be used for alternate 
routing paths. ("Adaptive energy-conserving routing for multihop ad hoc networks", 
Tech. Rep. 527, USC/lnformation Sciences Institute, Oct. 2000) The assumption 
here is that the underlying routing will be based on conventional ad hoc routing 

20 protocols such as the AODV system already discussed. Sensor networks, however, 
typically would require a lighter weight approach to routing, where decisions are 
based on information from immediate neighbours only, and this knowledge needs to 
be conveyed succinctly, ideally as part of the packet headers for the actual data to be 
collected. 

25 A lot of work has been done at the University of California and the Intel 

Berkeley Research Lab, to develop operating systems and networks for small ad hoc 
sensor devices, known as the Smartdust project, for which an operating system 
known as TinyOS has been developed (DE. Culler, J Hill, P Buonadonna, R 
Szewczyk, and A Woo. "A Network-Centric Approach to Embedded Software for 

30 Tiny Devices". DARPA Workshop on Embedded Software. However, the routing 
scheme they refer to is not power-aware, but rather uses a hierarchical structure to 
find shortest paths to the sinks. 
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So. ,n summary, there ere established routing protoools for erf hoc networks 
the, ere too resource-intensive for sensor networks end ere no, power-ewere- there 
ere power-ewere me,rics which heve no, been eppiied ,o erffroc ne,„orks; ,here ere 
power-aware s,re,eg,es for erf hoc sensor nefworks ,he, do no, op.imiae ,he rou,,ng- 
end .here is an extensive erf h oc sensor network projec, wrthou, power-ewere 
routing. Note ,ha, none o, this prior work refers ,o highiv mobile erf hoc devices of 
the k,nd ,o which ,his invention is psrticulerly directed. 

As elreedy discussed, prior er, routing mechenisms require fe, more memory 
end processing power ,hen is sunabie for lightweigh, environment sensor devices 
or essume el, devices cen communing diredy wi,h ,he sinks. Also, only ,he ful, erf 
hoc protocols cen cope wi,h device mobile, end these require e lerge communice,ion 
overhead. 

Because the devices are moving rapidly, even their nearest neighbours may 
change between data transmissions. Routing decisions must be made 'on-the-fiy- 
15 using very recently gathered information. 

In this specification, the term "payioad data" is used to mean the usefui data 
which it is desired to transmit, as distinct from overhead data used to control routing 
of the payioad data. Note that there is some degree of overiap between the two 
types of data: for example the position of the device is necessary for routing 
20 purposes, but is also likely to be an important part of the information collected by the 
sensor for example in the study of ocean currents or animal migratory behaviour 

According to the invention, a mobile data wireless relay device is provided 
the device having 

receiving means for receiving payioad data from a data source, 
25 a buffer for storing payioad data for subsequent transmission, ' 

means for receiving status data from similar devices, 

status data generation means for generating status data, the status data 
bemg derived from the quantity of data in the buffer store and the status data 
rece,ved from other devices, and comprising data relating to 
30 the position of the device, 

the quantity of data in the buffer store 
a scalar forwarding value («5) and 
a forwarding direction, 
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payload data will be received by a device according to the invention from similar 
devices, which will have identified it as being in the general direction of their own 
negative nodes. 

Preferably, the positions of the positive and negative nodes are determined 
5 by determining the position in which the aggregate value of the products of the 
attribute values of each node with each node of one or more neighbouring devices, 
and some arithmetical function of the distance between them, is a minimum or 
maximum. In the embodiment to be described, the simple reciprocal of the distance is 
used. 

10 Tne spacing between the positive and negative nodes defined by the device 

is preferably on a similar scale to, but not larger than, the transmission range of the 
device. The payload data may be received from another similar device, or generated 
by the device itself. Some or all of the wireless relay devices may therefore comprise 
data gathering equipment for generating new data for transmission. In the preferred 

1 5 embodiment each data collection device can also act as a wireless relay devices to 
retransmit data received from other such devices. However, the scope of the 
invention does not exclude the presence in the network of some devices that can 
only transmit data to other devices. Any such device would act as a "source" or 
"negative sink", and would be defined by a single node with a negative attribute q. 

20 Devices capable of interacting with the wireless relay devices may also be 

provided, capable only of reception. They act as information "sinks", and would 
typically be used as the interfaces between the mobile data gathering network and 
the fixed data-processing system. Such a device is represented as a single node 
having a positive attribute value q. In a preferred arrangement, the sinks are 

25 allocated the maximum attribute value q, and the mobile devices have attribute 
values whose magnitudes are sub-maximal. 

A pair of devices, acting in isolation, would tend to align their node pairs 
such that all four nodes {three nodes if one of the devices is a source or a sink) 
define a straight line, with the negative node of one of the devices adjacent to the 

30 positive node of the other. If there are more than two devices, they will interact in a 
more complex manner, the alignments of the nodes of each device being determined 
not only by the direction of each neighbouring node and the sign of its attribute 
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vaiue, but aiso by the distance between , he nodes and the magnitudes of their 
attribute values. 

The wireless relay devices therefore define a preferred direction for payload 
data to travel, namely from the negative node of one device towards the positive 
node of another. If one imagines a line of devices with a sink at one end, the device 
closest to the sink can express the direction of the sink from itself by the alignment 
of ,ts positive and negative nodes. The next device in the line may be too far from 
the sink to be able to transmit directly to it, but can a.ign its node pair with the 
forwarding direction of the device closest to the sink. Specifical.y it will be aligned 
w,th ,ts negative node closest to the positive node of the first device, and so on 
along the line of devices. Consequently, even the device at the furthest end of the 
line can set its forwarding direction so as to join the path to the sink. 

In a real two- or three-dimensional system, devices will not form simple 
chains but will form branched chains converging on the sink or sinks. In order to 
accommodate the influence on each device of several other devices, the local 
forwarding direction is chosen to be the sum of all the alignment influences from its 
nearest neighbours. The orientation which produces the optimum value is defined as 
the local forwarding direction. Note that this takes into account not only the position 
and alignment of devices to which data may be sent, but also of those from which it 
may be received. 

Preferably a forwarding trigger value is calculated, to determine whether 
payload data should be forwarded. This trigger value determines whether a chain has 
been formed, and therefore whether it is worthwhile to forward data. This 
computation depends on the use of a further attribute, S, which is essentially a 
variable part of the attribute value a, and depends on the proximity, and attribute 
values, of neighbouring devices, .n the preferred embodiment battery level is used as 
a further determinant, to ensure that devices whose batteries are depleted forward 
the,r data with greater urgency than those with more battery fife remaining 
emulation results show that setting a trigger level delivers a significantly higher 
proportion of data back to the sinks than a method that relies only on forwarding 
towards the nearest sink. 

The devices have no information about whether they are in fact in a chain 
leading to a sink - they- simply pass data to a neighbour if certain conditions are metT" 
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As the devices are mobile, from time to time they may find themselves at locations 
from which no viable chain can be defined towards a sink. In such cases data can be 
stored in their buffers until communication is re-estabiished . Since the attribute value 
q is determined by the size of the buffer (or by the available space in the buffer), one 
5 device having a full buffer may forward data to another device having more space, 
even though the receiving device is currently unable to forward it. This makes more 
space available in the buffer of the transmitting device, allowing it to collect more 
data, either from other devices or from its environment. The receiving device would 
retain the transferred data until it in turn can forward it. 

10 The wireless relay devices may use directional antennas for transmission and 

reception of data signals. However, because the alignments selected are based on 
the aggregate influence of several neighbouring devices, the antennas would have to 
be of relatively wide beam width. This could be achieved using a multi-sectored 
antenna with an integrated beam-forming and switching circuit that allows the 

1 5 antenna to form a number of discrete beams, which can be selected individually or in 
groups to transmit and receive in a specific direction, or can all be combined to 
provide omni-directional coverage. It would then be possible to determine the 
direction of send signal, as long as devices had a reference direction (digital 
compass). Such a system would not require mechanical rotation (with the 

20 consequent power and wear implications) However, although such antenna arrays 
are commercially available, they are currently too large and expensive for the cheap 
devices envisaged. Moreover, although the positions of the nodes defined with 
respect to each device may be varied according to the positions and other 
characteristics of the neighbouring devices, the physical orientation of the device 

25 itself is not affected. The physical orientation is determined by the forces causing it 
to move through its environment, such as ocean or wind currents, or the behaviour of 
the object to which it is attached, such as an animal whose migratory behaviour is 
under study. If directional antennas are used, means for accommodating the 
essentially random orientation of the device would need to be provided. 

30 Although they would reduce the power consumption required for 

transmission, directional antennas would therefore be difficult to accommodate and 
control in very small devices. In a preferred embodiment each wireless relay device 
has an address code to which data intended for that device should be sent. This 
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complete route back to a sink is given by a chain of wireless relay devices, where 
each wireless relay device is within forwarding range of the previous device in the 
chain. Such a structure may only exist quite briefly, as the devices move around. 
Indeed, the complete chain may not all exist at the same time, the individual hops 
5 coming into existence at different times as the devices move around. 

The invention could also be used to route packets in multi-hop cellular 
networks to a nearby base station. No sensor-network-specific assumptions are 
made, e.g. that all nodes generate data. Extension to general ad hoc networks, 
where any node can send to any other, would involve the nodes maintaining a 
10 number of forwarding directions, for different target nodes. In order to overcome 
scaling difficulties, in such a case, the nodes could be organised into hierarchical 
clusters, with nodes needing to have forwarding directions to forward to cluster- 
heads and to nodes within their own clusters. 

The invention allows the collection of data from an ad hoc network of highly 
1 5 mobile sensor devices, to one or more "sink" devices, which may also be mobile, in a 
way that is distributed, robust and lightweight. 

Preferably the routing takes account of the battery and memory levels of 
participating devices, so that devices which are low on resources are less heavily 
loaded. However, only information from a device's immediate neighbours is 
20 available, so any decisions taken must be done on the basis of only a few parameters 
from a handful of nearest neighbours. This is because of the constraints on the 
devices' processing power and memory, as well as bandwidth which is severely 
limited as a result of small, finite battery power. 

An embodiment of the invention will now be described, by way of example 
25 only, with reference to the Figures in which 

Figure 1 is a schematic diagram of a device according to the invention 

Figure 2 is a diagram of part of an ad hoc network made up of devices of the 
kind shown in Figure 1 

Figure 3 is a flow chart showing the processes performed by an individual 
30 device, and the information it exchanges with similar devices, in order to determine 
the current values for the parameters used in the invention 
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Figure 4 is a further flow chart, showing the processes used to identify a 
destination device and to transmit data to it, using the parameters generated in the 
process of Figure 3. 

Figure 1 shows a device 20 according to the invention. It comprises a 
5 W1 re.ess transmitter 21 and a wire.ess receiver 22, and data col.ection means 23 
which include position sensors, and environmental or physiological sensors for 
determining properties of the environment of the device, or of some object to which 
-t ,s attached. There is also a data buffer 24 for storing payload data (that is to say 
data that is to be transmitted to a destination for processing, and a data store 25 for 
0 operational data (that is to say, data required for the operati.n of the device and in 
particular for controlling the transmission of the payload data,. There is also 
computation means 26 for processing the data collected by the data collection means 
23 and stored in the data buffer 24, and control means 27 for controlling the 
operation of the device in response to outputs from the computation means 26 The 
5 device is powered by a battery 28 whose condition is monitored and the results 
stored in the data store 25 with other operating parameters. The power connections 
themselves are not depicted in this schematic diagram,. 

Figure 2 shows a network comprising several devices 10, 20 30 40 50 
60, 70, 80, each of the type shown in Figure 1. These devices are free 'to move 
0 relative to each other through their environment, collecting data from their 
env.ronment such as temperature, barometric pressure, salinity etc,. They also record 
then- position. They may be carried by inanimate forces such as ocean or air currents 
lava or glacier flows, or they may be attached to animals or human beings to track 
their movements or physiology, or to a vehicle to monitor its progress on a Journey or 
to locate it if it is reported to have been stolen. 

The devices 10, 20, 30, 40 etc shown in Figure 2 form an «/ hoc wire.ess 
network 19, 29, 39, 49, etc. The wireless connections may use radio, sonar or any 
other transmission medium suitable for the environment in which the devices are 
expected to operate. Data collected by a device 20 (either by its own sensors 23 or 
relayed from another device 10, is transmitted to a destination 90 either directly or 
by means of one or more other devices 30. These other devices may also collect 
data. The destination 90 is a fixed receiver station, which will be referred to as an 
- -.nformation -sink", and which collects- data -collected by the mobile terminals 1 0 20 
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30 etc for subsequent processing. There may be more than one sink in the network. 
The sink device 90 is more powerful than the sensor devices 1 0, 20 30 etc, both in 
terms of processing capability and power-consumption, and either have long-term 
storage facilities for the data, or a long-range transmission link 98 to a data- 
5 processing centre 99. The sensor devices 10, 20, 30 themselves have very limited 
battery power (allowing only short-range wireless transmissions), small processors 
and limited memory. 

As the devices 10, 20 etc move around, the wireless links 19, 29, 39 etc 
between them have to re-arranged in order to provide the optimum network. As well 
10 as physical location, factors such as the spare capacity of the buffer store 24 and the 
battery 28 are taken into account in determining whether a wireless link 29 should be 
established between two devices 20, 30. The process by which this is done will be 
described in detail shortly. 

When a device 20 has identified a device 30 to which data can be 
1 5 forwarded, it retrieves data from its buffer 24 and transmits it to the target 30. The 
device 30 then repeats the process of identifying a suitable neighbour and so on, 
until the data reaches the sink 90. If no suitable device is identified, the data is 
stored in the buffer 24 until the movements of the devices brings a suitable device 
into range. 

20 In general, it is desirable that the devices transmit data in the general 

direction of the nearest sink 90. Thus when two devices 20, 30 come into proximity 
to each other, a direction 200 needs to be determined to identify which device 20 
should transmit data and which device 30 should receive it. This direction 200 will be 
referred to as the "forwarding direction" for a given device 20, and defines a receive 

25 end 201 and a transmit end 202 for the device 20. The device also determines 
whether to forward data to the nearest neighbour 30 whose location is in this 
direction, based on the separation of the devices 20, 30, and other characteristics, as 
will be described in detail later. 

If a sink 90 is within direct transmitting range (as for example is illustrated 

30 for device 30), the forwarding direction will be towards the sink. Any device 20 
which is not in range of a sink are arranged to align its forwarding direction 200 
towards the receive end of one or more neighbouring devices 30. Thus a network 1 9, 



30388.doc 



14 



29 39 e ,c wi„ be defined. each devIce havi „ g ^ ^ 
of the rece.ve end of the next device until they reach e sink 

Figures JIT" emb0di ' nen, * «** — - 

5 Ea ° h m ° b " e deviM < 20 ««) initieily measures and stores a number nf 

attnbutes releting to M (step 31 1,. These ettributes are- 

fiyfie^SO A X e scalar quantity representing the amount of data awaiting 
«ransm,ss,on, expressed as a fraction of the ,o,a, cepacity o, tha buffer 24 

,0 ^T^^- fl * an ° ther SOa ' ar ~ r ~"« *» ~ ««e o, 
fitfttD. P. a pair of co-ordinates ,or e triple, if three dimensiona are needed, Tha 
posmon w„, be Known since environment ors need to be abie to determine 2 

a GPS (QtoM Posmonmg System, sensor for this purpose. A,ternetiva,y, provided a. 
15 east one dev,ce can determine its absoiute position, the absolute position o, JZ 

20 more neiiruZtrr ^ ^ ' —~ °' « - 

measuring the distance to said one or mora neighbouring nodes; and 
iterativeiy modifying an astimatad ,oca,ion of the device, auch as to improve 
«h constancy between the estimated iocation of the device and the locatio o 
2 5 -mated location o, the one or more neighbouring nodea. as determined om ,h 
obtained mformation apecifying the iocation or estimated iocation of the ona or ml 
narghbounng nodes, on the one hand and the measured distances to each of the on 
or more neighbouring nodea on the other hand. 

30 (step 3,* IT Va ' U9S f" BX "* POSWOnS ° ther are defined 

(step 31 2) for two v«ua, nodea 201. 202 , referred to herein aa the positive node 
and the negatrva node. The nodes ere contained to be ,oca,ed a, diametrica 
opposed pomts P. P. on a circle 23 (or a sphere in a three dimenaiona, embo la 
centred on the device ,0.- The diameter d, o, the CrCe is a function of .h^t «• - 
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A x . Thus the actual position P x of the device 20 is the mid-point of a line of length d 
joining the positions P + P. of the two nodes. The orientation of this line is initially 
arbitrary (it may be defined with reference to the device itself or a compass bearing, 
or a previous position), but it subsequently takes up a position 200 determined by the 
5 properties of neighbouring devices 10, 30, 40 etc. 

The nodes 201, 202 represent an input direction and an output direction for 
the device 20. These are the directions respectively in which data is to be forwarded, 
respectively, to and from the device 20. However, it should be clearly understood 
that the nodes 201, 202 are purely points in space, defined with respect to the 

10 relative positions of the device 20 and its neighbours. Unless directional antennas are 
to be used, it does not relate to the actual orientation of the device itself, which may 
be changing rapidly for example if the device is in a turbulent fluid. A network sink is 
represented as a single positive node, co-located with the device 90 it represents. 

Each node is attributed an influence value Q +i Q.. This influence value is a 

1 5 measure of the ability of that node to influence the nodes of other devices 1 0, 30, 40 
etc. The positive node of each mobile wireless relay device has an activity value Q + 
whose value is a positive number. The output end has a negative activity value Q = 
-Q + equal in magnitude to the influence value of the positive node. The scalar 
magnitude of the influence values of the node pair has two components: an intrinsic 

20 component q which is simply a function of the buffer size A x , and is independent of 
other devices, and an induced component 8, which is influenced by neighbouring 
devices. As will be discussed later, the value of the induced component 8 depends on 
the positions and influence values of the neighbouring devices, and their ability to be 
influenced by other devices a*, which is again a function of the buffer size A x . 

25 The Properties d, q, and a are selected such that the strongest interactions 

occur between a device with a full buffer (A = 1) and another device with an empty 
buffer (A = 0). The influence value Q s for a sink 90 is set at the maximum value. In 
this embodiment Q s = 1 , and all other devices have fractional values for Q. These 
properties could be allowed to vary continuously according to the quantity of data in 

30 the device's buffer, but to reduce the memory and calculation required this 
embodiment quantifies buffer size as one of a small number of levels, for example 
empty, full, and three intermediate levels - each level having a specified value for 
each property d x , q x , a*. This requires the devices 20 etc to store just (5 levels x 3 
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properties! - 1 5 values, minimising the memory required of th. H. • « 

cen then determine the values of d n , A " V deVi ° e 

from the buffer s, Z e oate^ al "* ** " *" "* — 

. ^—ZlZ 1 "; ^T" 9 d,rect,on ,or a x - -* *• 

component fc is se, a, " ^ ™ ^ W ~> *• 

de,eo„ ng ,h,s broadoast responds ( s,ep 3,4, with the positions P P of', 

. nodes the, separation d v oan he determined^ nTTit'T 
and henoe the permanent influenoe valuea q „ , <, of the * £ 

Us,n 9 the position and influenoe ettrihutes received from its neighbours a 
device X can then determine a scaiar interaction vaiue U, -g (step „„ 

for both nodes / of the device performing the calculation aid all L.. ■ « 
neighbouyring devices 10. 30 40 etc =„„ , „ • 7 °' a " V 

and node j. w Note tha, the 1 T " ** d ' S,anCe De,WMn n °*° ' 

- — ~zzzzi :rrit=r: 

simplified to C/^ =^ + (^ gy 

> 0 + / 0- 

where Px+ is the influence value of the positive node of device X and r ■ * 
distance between the positive node of device X and noH • 7 ' + 
••3 the distance between the ne g ative nod o ll 7 T ** * 

25 As the nodes are merely virtual ooint, • ' an ° ther 

•*^^+i^™:^2r~ ,hat nodes of 

Thus, for each of the two nodes i of the device X .,„*„, 
aggregate veiue of the influence attributes of each 2 7 the 
ca,cu,a,ed. weighted for distance r. (Since r-0 wolT d , ^ * 

30 the value of -r" i. ht w ,. ' n ° e r "° would lead «° infinite value for U,, 
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whose activity attributes q + q.are equal and opposite, but whose distances rfrom any 
other given node j will generally be different, as one node will be nearer than the 
other. Thus the number of interactions to be determined is 4n where n is the number 
of neighbour devices - each neighbour has two nodes, and the interaction of each 
5 neighbour node is considered with each of the device's own two nodes. 

The orientation 200 of the nodes 201, 202 in the device is initially arbitrary: 
but having established a value for U x the positions of the nodes are now redefined to 
be rotated about the centre P x (the actual location of the device X) (step 317) and a 
new value of U x is calculated (repeat step 316). In the present embodiment eight 

10 orientations are assessed in this way, spaced at 45 degrees. Note however that the 
positions of the nodes P x+ , P x _ are symmetric about the centre P x , and they differ 
only in the sign of their influence values Q. Consequently only four calculations need 
to be performed - the other four have the same magnitudes, but opposite signs. 

An optimum orientation 200 is then determined (step 318) - this is the 

1 5 orientation giving the minimum value of U x . This orientation 200 is then maintained 
for subsequent steps of the process, and the positions P + P- of the nodes 201, 202 
are stored (step 319) for transmission to other devices 10, 30, 40 when they request 
them, to use in their own computations. If each device maintained constant values 
for positions P and buffer states A, (and hence influence value Q) their node 

20 orientations would eventually reach a steady state. However, in practice, the devices 
are moving and transferring data, so these values are constantly changing. 

Any device 30 that detects a sink 90 in the vicinity would therefore generate 
an orientation for its node pair whose direction is towards the sink 90. Such a device 
30, in turn, has a knock-on effect on other nearby devices 20, 50 that are too far 

25 away from the sink 90 to forward to it directly, and these nearby devices 20, 50 will 
also influence devices 10, 40 yet further away from the sink 90, to orient their 
forwarding directions so as to make a path to the sink 90, via the intermediate 
devices 20, 30 (for example path 19, 29, 39). The result is that, irrespective of 
network topology, all devices (unless entirely cut off by distance from regions of the 

30 network that have paths to a sink 90) will have a forwarding direction 200 that is 
likely to enable transmission of data to a sink 90. 

The aggregate alignment influence of neighbouring devices is therefore 
determined quantitatively, according to the separation of the devices r, and their 
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where 5 /is the induced component of Q for a node j of a neighbouring device, 
a x \s the measure referred to above of the degree to which the node X can be 
influenced, d x is the spacing between the nodes of device X, and q x is the permanent 
influence value of device X, all of which values are derived from the buffer size A x . q a 
5 is the influence value of a neighbouring node at distance r xj . If this induced value 
exceeds a pre-set threshold, then data is forwarded to the nearest device to the 
negative node of the device, provided that this neighbouring device is within 
transmission range. 

The induced value, S x , is compared with a fixed threshold 5 mIn , (step 41 2) . 
10 The nearest device 30 to the negative node P. (202) is identified from the position 
data of the neighbours (step 413). The distance r of this device is determined (step 
414 and compared (step 416) with a broadcast range R. A check is made (step 417) 
to ensure the payload data did not originate from the target neighbour device. Lastly, 
the invention restricts the choice of influencing neighbouring devices to exclude from 
15 consideration any subject device from which data has recently been received. This is 
to stop data "ping-ponging" backwards and forwards. Larger loops may occur briefly 
from time to time, but they would be unlikely to persist for long as the relative 
positions of the sensors change, and in the absence of a sink node in the vicinity. 

The broadcast range R is determined (step 415) according to the ratio of 
20 (battery power left)/(time left), as follows: 

B — B 

R = range^ + 0 — (range ^ -range min ) , 

Z Vmax */ 

where B is the current battery level and i? 0 is the initial battery level, and tand 
t max are the current time and length of the data-gathering experiment respectively; 
range is not allowed to exceed range max . 

25 If the neighbour device 30 is within broadcast range (r<R) and the other 

conditions referred to above are met the payload data is retrieved from the buffer 
store 24 and addressed to the neighbour device 30 using its id code (step 418). 

More sophisticated controls could be used, based on the quantity of data left 
in the device buffer, perhaps, but this simple approach has been shown to give 

30 advantage compared with a range that is independent of battery power, and it is easy 
for simple devices to calculate. 
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If a device 20 is cu« off from any path ,o a sink 90 i, oan simply store any 
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may on,y ooourwhen a deyioe20 oomea within direo, range o, a aink 90. in denaely 
popped networks paths having a ,ar 3 er number of hope ,9. 29. 39 wii, b e ml 
common. The prooeaa is flexible enough to oope w„h a wide ran 9 e of 
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10 variations requiring special treatment. 
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been found to route data so tha, ,esa transmission energy is used for forwarding 

alay I! 5 r9C ° Vere f d ' 8nd ,aWer h ° PS " eeded tha " ^ 3 ^ °~ 
always chooses to forward in the direction of the nearest network aink. The 

invention has the ability to convey ionger-range network structural information than 
wouid otherwise be available to the mobile devices, through the interactions of their 
preferred forwarding directions. 
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CLAIMS 

1 . A mobile data wireless relay device, the device having: 
receiving means for receiving payload data from a data source, 

5 a buffer for storing payload data for subsequent transmission, 

means for receiving status data from similar devices, 

status data generation means for generating status data, the status data 
being derived from the quantity of data in the buffer store and the status data 
received from other devices, and comprising data relating to 
10 the position of the device, 

the quantity of data in the buffer store 
a scalar forwarding value and 
a forwarding direction, 
status transmitter means for transmitting status data to other devices 
1 5 selection means for identifying from the status data a receiving device to 

which the payload data is to be forwarded, the receiving device being located in a 
position indicated by the forwarding direction, 

payload transmission means for transmitting the payload data to the 
receiving device. 

20 

2. A mobile data wireless relay device according to claim 1, comprising means 
for receiving payload data transmitted by other similar devices. 

3. A mobile data wireless relay device according to claim 1 or claim 2, further 
25 comprising a data source 

4. A mobile data wireless relay device according to any preceding claim, 
wherein the selection means is arranged to only identify a suitable receiving device if 
the scalar forwarding value meets a threshold criterion. 

30 

5. A mobile data wireless relay device according to any preceding claim, further 
comprising condition-monitoring means for monitoring the expected lifetime of the 
device, and adjusting the scalar forwarding value accordingly. 
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6. 



A mobile data wire.ess relay device according to any preceding claim 
composing means for defining a first node and a secpnd node, the nodes being 
spaced apart by a distance determined by the amount of data stored in the buffer 
the f,rst node being assigned a positive value for an attribute q and the second node 
bang assigned a negative va.ue for the attribute q, equal in magnitude to that 
assigned to the positive node, 

the wireless relay device has means for receiving data broadcast by similar 
wreless relay devices identifying the position data and attribute values of nodes 
defined by the similar wireless relay devices, 

means for generating position values for the first and second nodes based on 
the attribute values of its own nodes and the positions and attribute va.ues of the 
nodes defined by the neighbouring devices, 

means for transmitting the position data and attribute va.ues to similar 
wireless relay devices 

means for transmitting payload data to devices that are in. the general 
direction of the second node. 



A mobile data wireless ralay device according to any pracading claim, 
wherein tha positions of tha first and sacond nodas ara datarminad by determining 
20 tha position in which tha aggragata vaiua of tha products of tha attributa vaiues of 
aach noda with aach noda of ona or mora naighbouring davicas. and an arithmetical 
function of tha distance batwean thorn, is a minimum or maximum. 

8. A natwork cf wiraiass ralay davicas comprising a plurality of mobila wiralass 
25 ralay davicas capabla of racalving payload data, and aach having moans for 
idantifying a forwarding direction relative ,o itself, and means for transmitting data to 
another of the devicea whose current position is in the said forwarding direction and 
wrthrn a predetermined distance, wherein the devices co-operate to define their 
forwarding directions such ,ha, payload data is transmitted to a targe, sink device by 
30 means of one or more of the wireless relay devices. 
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9. A network of wireless relay devices according to claim 8, wherein each 
device defines a positive receive node and a negative transmit node, spaced a 
predetermined distance apart, and the devices co-operate to define the positions of 
the nodes so as to minimise the aggregate distances between nodes having opposite 

5 signs, and wherein the forwarding direction of each device is defined as the direction 
from its receive node in which its transmit node lies. 

10. A method of operating a plurality of mobile data wireless relay devices, 
comprising: 

0 collecting data in buffer stores in one or more such devices, 

exchanging status data between the devices, the status data comprising data 
relating to 

the positions of the devices, 
the quantity of data in their buffer stores 
5 each device defining, from the status data, a forwarding direction towards 

which the payload data in its buffer store is to be forwarded, 

transmitting the stored payload data to a device located in the forwarding 
direction. 



20 11. A method according to claim 10, wherein data is only transmitted from a first 
device to a second device located in its forwarding direction if a scalar forwarding 
value derived from the status data exceeds a predetermined value. 

12. A method according to claim 10 or 11, wherein the status data includes a 
25 measure of the expected lifetime of the device, 

13. A method according to claim 10, 11 or 12, wherein each device defines a 
first node and a second node, the nodes being spaced apart by a distance determined 
by the amount of data stored in the buffer, the first node being assigned a positive 

30 value for an attribute q and the second node being assigned a negative value for the 
attribute q, equal in magnitude to that assigned to the positive node, 

generating position values for the first and second nodes based on the status 
data of the device and neighbouring devices, 
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devices tranSmittin9 POSiti ° n ^ and attribute val -s to simi.ar wireless relay 
transmitting pay.oad data to devices that are in the genera, direction of the 



second node 
14. 



A method according to claim 13, wherein the positions of the first and 
second nodes are determined by determining the position in which the aggregate 
value of the products^ the attribute va.ues of each node with each node of one or 
more neighbouring devices, and an arithmetica, function of the distance between 
iu them, is a minimum or maximum. 

15. A method according ,o claim 14. wherein the devices co-operata to define 
the positions of the nodes so as to minimise the aggregate distances between nodes 
havmg opposite signs, and wherein the forwarding direction of each device is defined 
5 as the direction from its receive node in which its transmit node lies. . 

16 A method according to claim 13. 14 or 1B wherein ,he devices co-operate to 
dehne their forwarding directions such the, payload data is transmitted, by means of 
one or more of the wireless relay devices. ,o a target sink device defined by a receive 
node. 
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ABSTRACT 

Ad Hoc Communications System 

5 A number of data collection devices 10, 20, 30, 40, 50, 60, 70, 80, are free 

to move relative to each other through their environment, collecting data from their 
environment. They form an ad hoc wireless network 19, 29, 39, 49, etc in which 
data collected by a device 20 (either by its own sensors 23, or relayed from another 
device 10) is transmitted to a destination 90 either directly or by means of one or 

10 more other devices 30. The destination 90 collects data collected by the mobile 
terminals 10, 20, 30 etc for subsequent processing. The wireless links 19, 29, 39 
etc between them have to re-arranged in order to provide the optimum network. 
When two devices 20, 30 come into proximity to each other, a forwarding direction 
200 is determined to identify to which device 30 data should be forwarded. The 

15 devices co-operate to define their forwarding directions by exchanging data relating 
to their physical locations, and factors such as the spare capacity of their buffer 
stores, and battery condition. Thus a network 19, 29, 39 etc will be defined 
dynamically, each device having its forwarding direction 200 aimed in the direction of 
the next device until they reach a sink. 

20 

(Figure 2) 
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